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METHOD AND SYSTEM FOR WEB USER PROFILING AND SELECTIVE 

CONTENT DELIVERY 



60/154,640 filed on September 17, 1999 and entitled "Method and Apparatus for 
Predictive Marketing." 

Background of the Invention 

Field of the Invention 

The present invention relates generally to methods of profiling Web users 
and for delivering targeted content to users. 

Description of Related Art 

Web advertising (typically banner advertisements) directed to Web users is 
expected to grow rapidly along with the growth of the Internet and E-commerce 
activity. Traditional methods of Web advertising have been found to be generally 
ineffective in drawing responses from Web users. For example, research has shown 
that few online users regularly click through ordinary banner advertisements. 

A more effective means of Web advertising is advertising targeted to 
particular Web users. For example, it is known to profile Web users by determining 
their demographics and interests, and to selectively transmit advertisements to only 
those users having particular profiles. Information on users can be obtained, e.g., 
from the users themselves through questionnaires. However, in these profiling 
methods, there is no assurance of user privacy or the accuracy of the profiling data. 
Also, there is no way of accurately matching the advertising to user profiles. 



Related Application 

The present application claims priority on Provisional Application Serial No. 
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A need exists for a method and system for accurately and anonymously 
profiling Web users. A need also exists for a method and system for accurately 
matching users of given profiles to content to which they will likely be most 
receptive. 
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Brief Summary of the Invention 

The present invention is directed to a method and system for accurately and 
anonymously profiling Web users and for selectively delivering content such as 
advertisements to users based on their profiles. The system uses behavioral 

5 information preferably collected at the users' point of connection to the Internet to 
anonymously profile their interests and demographics. It accurately matches and 
delivers content to the users to which they will likely be most receptive. Advertisers 
can use the system to launch effective advertising campaigns delivering selected 
Web content to chosen target audiences. The system uses feedback from users to 

10 determine the effectiveness of an advertising campaign and allows dynamic 

modification of the advertising campaign by, e.g., altering the target audience, to 
optimize results. 

These and other features and advantages of the present invention will 
become readily apparent from the following detailed description wherein 

15 embodiments of the invention are shown and described by way of illustration of the 
best mode of the invention. As will be realized, the invention is capable of other 
and different embodiments and its several details may be capable of modifications 
in various respects, all without departing from the invention. Accordingly, the 
drawings and description are to be regarded as illustrative in nature and not in a 

20 restrictive or limiting sense with the scope of the application being indicated in the 
claims. 
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Brief Description of the Drawings 

For a fuller understanding of the nature and objects of the present invention, 
reference should be made to the following detailed description taken in connection 
with the accompanying drawings wherein: 
5 FIGURE 1 is a block diagram illustrating of a representative network in 

which the inventive system is preferably implemented; 

FIGURE 2 is a block diagram illustrating the preferred overall architecture of 
the inventive system; 

FIGURE 3 is a block diagram illustrating the data collection component of the 

10 inventive system; 

: FIGURE 4 is a block diagram illustrating the client profiling component of 

the inventive system; 

FIGURE 5 is a block diagram illustrating the direct client communications 
component of the inventive system; 
15 FIGURE 6 is a screen shot of an exemplary pop-up advertisement in 

accordance with the invention; 

FIGURE 7 is a block diagram illustrating the master server synchronization 
component of the inventive system; 

FIGURE 8 is a block diagram illustrating the dynamic campaign manager of 

20 the inventive system; 

FIGURE 9 is a block diagram illustrating the data analysis system component 

of the inventive system; 

FIGURE 10 is a block diagram illustrating the billing component of the 
inventive system; and 
25 FIGURE 11 is a block diagram illustrating the data transfer from a ratings 

service to the inventive system. 
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Detailed Description of Preferred Embodiments 

The present invention is directed to a method and system for profiling Web 
users or clients based on their surfing habits and for selectively delivering content, 
e.g., advertising, to the users based on their profiles. 

5 FIGURE 1 illustrates a representative network in which the inventive system 

can be implemented. The network includes a plurality of client machines 10 
operated by various individual users. The client machines 10 connect to multiple 
servers 12 via a communication channel 14, which is preferably the Internet. It may, 
however, alternatively comprise an Intranet or other known connections. In the 

10 case of the Internet, the servers 12 are Web servers that are selectively accessible by 
various clients. The Web servers 12 operate so-called "Web sites" and support files 
in the form of documents and pages. A network path to a Web site generated by the 
server is identified by a Uniform Resource Locator (URL). 

One example of a client machine 10 is a personal computer such as a 
15 Pentium-based desktop or notebook computer running a Windows operating 

system. A representative computer includes a computer processing unit, memory, a 
keyboard, a mouse and a display unit. The screen of the display unit is used to 
present a graphical user interface (GUI) for the user. The GUI is supported by the 
operating system and allows the user to use a point and click method of input, e.g., 
20 by moving the mouse pointer on the display screen to an icon representing a data 
object at a particular location on the screen and pressing on the mouse buttons to 
perform a user command or selection. Also, one or more "windows" may be 
opened up on the screen independently or concurrently as desired. 

Client machines 10 typically include browsers, which are known software 
25 tools used to access the servers 12 of the network. Representative browsers 

include, among others, Netscape Navigator and Microsoft Internet Explorer. Client 
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machines 10 usually access servers 12 through some private Internet service 
provider (ISP) such as, e.g., America Online. Illustrated in FIGURE 1 is the ISP 
"point-of-presence" (POP), which includes an ISP POP Server 16 linked to the client 
machines 10 for providing access to the Internet. The POP server 16 is connected to 
a section of the ISP POP local area network (LAN) that contains the user-to-internet 
traffic. As will be discussed in detail below, the ISP POP server 16 captures URL 
page requests from individual client machines 10 for use in user profiling and also 
distributes targeted content to users. Also, as will be discussed in detail below, the 
inventive system also preferably includes a remote master server 18 linked to the 
ISP POP server 16 through the Internet. The system software is preferably 
distributed over the network at client machines 10, the ISP POP server 16, and the 
master server 18 as will be discussed below. 

As is well known, the World Wide Web is the Internet's multimedia 
information retrieval system. In particular, it is a collection of servers of the Internet 
that use the Hypertext Transfer Protocol (HTTP), which provides users access to 
files (which can be in different formats such as text, graphics, images, sound, video, 
etc.) using, e.g., a standard page description language known as Hypertext Markup 
Language (HTML). HTML provides basic document formatting and allows 
developers to specify links to other servers and files. These links include 
"hyperlinks," which are text phrases or graphic objects that conceal the address of a 
site on the Web. 

. e *GS y A-HS^rof a client machine having an HTML-compatible browser (e.g., 
Netscape Navigatorfc^r««trkve a Web page (namely, an HTML formatted 
document) of a Web site by specifym^r^wk^via the URL (e.g., 
www.yahoo.com/photography). Upon such specm^c^tiein^the client machine 
makes a transmission control protocol /Internet protocol (TCP/IP , J s request to the 
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The inventive system profiles Web users based on their surfing habits and 
also selectively and intelligently delivers content such as advertising to users based 
on their profiles. FIGURE 2 is a general overview of a preferred system architecture 
5 illustrating the interaction of the various system components. For convenience of 
illustration, selected components of the system are described below with respect to 
FIGURES 3-5 and 7-11. 

FIGURE 3 illustrates the data collection component of the system, which 
resides at the POP server 16 and gathers data used in user profiling. The data 

10 collection component captures URL requests from clients, associates the requests 
with particular clients, and stores the data in a database (the UserlD and URL 
database 30). The data collection component includes a sniffer 31 that monitors 
user-to-internet traffic. When the sniffer 31 detects an outgoing Web page request 
from a client 10, it captures the associated packets, extracts the actual URL request, 

15 and stores it in the database 30 along with the client's IP address. Because IP 
addresses are typically assigned dynamically, they are not necessarily the same 
every time a client logs into the ISP. To correlate an IP address with the associated 
client, the data collection component queries an IP address to anonymous user ID 
(AID) cross-reference table stored in another database at the ISP POP. It then stores 

20 the User ID and URL information in the database 30. 

FIGURE 4 illustrates the client profiling component of the inventive system, 
which extracts, derives and updates individual user (i.e., client) profiles based on 
their behavior on the Internet as indicated by the data found in the browsed URL 
database (i.e., the UserlD and URL database 30). User profile information may 
25 contain, but is not limited to, demographic data (such as, e.g., the user's age, gender, 
income, and highest attained education level) and psychographic data, which 
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reflects the user's interests or content affinity (such as, e.g., sports, movies, music, 
travel, and finance). The client profiling component first extracts data stored in the 
User ID and URL database 30. Next, it cross-references the URL strings with data in 
a local categorized URL database 32, which contains demographic information on a 

5 large number of Internet URLs available from entities such as Nielsen (through a 
service called Nielsen NetRatings) that profile Web sites using panels of users 
having known demographic characteristics. The client profiling component extracts 
a set of demographic data associated with a particular Web site URL from the 
database 32. The profiling component also extracts content affinity or 

10 psychographic data from a categorized listing of URLs that translate an address into 
a content preference for the profile also from database 32. 

Next, an existing user profile is pulled from a user profile database 34. Then, 
using a hybrid averaging algorithm, the URL demographic and content affinity data 
for URL requests made by a user and the user profile are combined to create an 

15 updated inferred user profile. One example of such an algorithm is an algorithm 
that provides a weighted average of the existing user profile data and the data 
gathered in the current Web browsing session. For example, the new user profile 
data equals the existing user profile data multiplied by the number of prior user 
sessions plus the new user profile data gathered in the current session, all divided 

20 by the sum of the number of prior sessions plus one. This is represented in the 
following equation: 

new user profile = (existing user profile X number of prior sessions + new 
user profile)/ (number of prior sessions + 1). 

This updated profile is stored back to the local user profile database 34. (If 
25 the user is new and no user profile exists, a profile is created using URL and content 
affinity data for URL requests made by the user.) 
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In addition to updating (or creating) the demographic and psychographic 
profile of the user, the client profiling component will preferably parse through 
requested URL strings to search for keywords (e.g., keywords that may have been 
entered into a particular search engine). If such key words are found, they are 
5 stored along with the user profile in the user profile database. 

As previously discussed, Web site profiles available from, e.g., Neilsen 
NetRatings are stored in the local categorized URL database 32. These Web site 
profiles are classified along multiple psychographic and demographic categories. 
As an example, the following 84 psychographic and 37 demographic categories can 
10 be used: 

Demographic Categories 
Gender: 

Male 

Female 

15 Age: 

0-11 
12-17 
18-20 
21-24 

20 25-34 
35-49 
50-54 
55-64 
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65-99 
Income: 

0-24,999 
25,000-49,999 
50,000 - 74,999 
75,000 - 99,999 
100,000 - 149,000 
150,000 and up 
Education: 

Some High School 
High School Graduate 
Some College 
Associates Degree 

Bachelor's Degree 

Post Graduate 
Occupation: 

Administrative or Clerical 

Craftsman 

Educators 

Executive 

Laborer 

Homemaker 

Military 
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Professional 

Sales 

Service 

Student 

Technical 

Self-employed 

Retired 

Race: 

Hispanic 
Non-Hispanic 
African American 
Caucasian 
Asian 

Native American 



Psychographic Categories 
Travel: 
Air 

Car Rental 
Lodging 
Reservations 
Maps 
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Finance/Investments: 

Banking 

Brokers 

Quotes 

Insurance 

Mortgage 
Sports: 

Auto Racing 

Baseball 

Basketball 

Fantasy Sports 

Football 

Hockey 

Soccer 

Golf 

Tennis 
Recreation & Hobbies: 

Cycling 

Golf 

Hiking 

Sailing 

Snow Sports 

Surfing 
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Tennis 

Home & Garden 
Pets 

Genealogy 
Photography 
Games 
Toys 
Entertainment: 

Movies /Film 

Music 

Theater 

TV/Video 

Sci-Fi 

Humor 

Games 

Toys 

Auto: 

Trucks 
SUV 

Sports car 
News and Information: 
Magazines 
Weather 
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Politics: 

Democrat 
Republican 
E-shopping: 

Groceries 

Furniture 

Auctions 

Cards /Gifts 

Apparel 

Books 

Music 

TV/Video 

Software 

E-purchasing 

Computers 

Software 

Science 

Employment 

Education 

Health & Fitness 

Medical 

Pharmacy 

Dating/Single 
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Advice 
Beauty 
Weddings 
Maternity 

Spirituality/Religion 

Astrology 

Discount 

Luxury 

Child 

Teens 

College Age 
Over 18 

Spanish Language 

For each visit to a Web site having a stored profile, the Web site profile is 
averaged or combined into the user's profile as previously discussed. The profiles 
include a rating in each category that reflects the interest in the category of persons 
who access the Web site. 

Each rating is accompanied by a confidence measure, which is an estimate of 
the accuracy of the rating. The confidence number is determined by analyzing the 
Web site and rating it on the type and specificity of content, with narrower and 
more singular content providing a higher confidence number. When the confidence 
measure in a particular category is below a predetermined threshold, information 
from other user profiles is preferably used to provide a more accurate rating in a 
process referred to as "profile completion." 
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An example of a user's profile is shown below. The first number in each 
category indicates the rating for that category. The ratings number is a percentage 
of a maximum rating, representing the degree of the user's affinity to the category. 
In the example below, the ratings number ranges from 0 to 100 with higher numbers 
indicating greater affinity. The second number in each category (in parenthesis) 
represents the confidence level in the rating for that category. 



User Profile 


User ID 


Sports 


Finance 


Movies 


Music 


TV 




Health 


Gardening 


1 


10.0(75) 


25.0 (.15) 


0.0 (1.00) 


0.0 (.28) 


0.0 (1.00) 




50.0 (.77) 


85.0 (.82) 



Suppose the confidence threshold is defined to be .50 such that confidence is 
insufficient in any rating that has a confidence measure less than .50. For the user 
profile in the example table shown above, there is insufficient confidence in the 
ratings for the finance and music categories. In this situation, the system examines 
profiles of users with similar profiles to improve the accuracy of the ratings in those 
categories with low confidence measures. 

A clustering algorithm can be used to find profiles that are similar to the 
profile of the current user. In judging the similarity between profiles, the 
confidence measures are ignored and the profiles are treated as n dimensional 
ratings vectors. A simple clustering algorithm is used based on the distance 
between vectors wherein all users whose profiles are within a certain distance of the 
subject user profile are collected. Then, the weighted average of all of the profiles in 
the collection is calculated to get an ideal profile for comparing to the subject user 
profile. If the ideal profile has a rating for the category in question that has an 
acceptable confidence measure, then this rating (and the accompanying confidence 
measure) replaces the corresponding rating in the subject user profile. In this way, 
parts of the user profile that have low confidence ratings are "completed" or "filled- 
in." An example is shown below. 
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Group similar profiles to generate an ideal profile to be used to complete the user's profile 


User ID 


Profile 


1 


10.0 (.89), 21.0 (.75), 0.0 (1.00), 17.0 (.74), 0.0 (1.00), .. 


...,52.0 (.64), 95.0 (.90) 


2 


12.0 (.77), 5.0 (.15), 0.0 (1.00), 12.0 (.85), 0.0 (1.00), .... 


,40.0 (.84), 90.0 (.75) 


o 


11.0 (.81), 20.0 (.77), 0.0 (1.00), 0.0 (1.00), 0.0 (1.00), .. 


....,75.0 (.77), 81.0 (.73) 


4 


10.0 (56), 25.0 (.68), 4.0 (.27), 11.0 (.77), 0.0 (1.00), .... 


55.0 (.80), 85.0 (.85) 


5 


12.0 (.75), 22.0 (.77), 0.0 (1.00), 10.0 (.83), 2.0 (.30), .... 


....,60.0 (.41), 80.0 (.45) 






Ideal 
profile 


11.0 (.76), 21.1 (.62), 0.9 (.85), 9.4 (.84), 0.5 (.86), 

. 


....,55.8 (.69), 87.1 (.74) 



In the example above, the ideal profile is calculated in the following manner. 
The rating for each category in the ideal profile is calculated by multiplying the 
rating times the confidence measure for each user. These products are then added 
across users in each category. This sum is then divided by the sum of the 
confidence measures added across users in the category. In mathematical terms, 
Ritoi j = I Ri j Cij / ZCy, where Rideaij is the rating for the ideal profile in category j, Ry 
is the rating in category j for user i, Cy is the confidence measure in category j for 
user i and the sum is taken over i as i ranges from 1 to n, which is 5 in this example. 
The confidence measure for each category in the ideal profile is calculated by taking 
the average of the confidence measure across users in the same category, 
C id eaij=5;Cij/n, where C id eai j is the confidence measure for category j in the ideal 
profile, Cy is the confidence measure in category j for user i, and the sum is taken 
over i as i ranges from 1 to n, which is 5 in this example. 

The ideal profile is used to complete the subject user profile. In the example 
described above, there was insufficient confidence in the ratings for the user in the 
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finance and music categories. Users having similar profile ratings to the user were 
found to have a finance category rating of 21.1 with a confidence measure of .62. 
Since the confidence threshold was defined to be .50, it is possible to use the ideal 
profile finance rating of 21.1 (.62) to replace the user's finance category rating of 25 

5 (.15). Similarly, the music category rating for similar user profiles was found to 
have a rating of 9.4 with a confidence measure of .84. This is greater than the 
threshold and is used to complete the subject user profile. The music category 
computation illustrates how the system is able to advantageously infer that the user 
may have an interest in the category despite the fact that he or she has not visited 

10 any Web sites related to that category. The completed subject user profile now 
appears as follows: 



'Completed' User Profile 


User ID 


Sports 


Finance 


Movies 


Music 


TV 




Health 


Gardening 


1 


10.0 (.75) 


21.1 (.62) 


0.0 (1.00) 


9.4 (.84) 


0.0 (1.00) 




50.0 (.77) 


85.0 (.82) 



In order to protect the privacy of users, the system does not keep data on 
which sites have been visited by users for any long term period. Once data in the 
15 User ID and URL database 30 has been used for updating a user profile, it is erased. 
Thereafter, it is not possible to match users with particular Web sites visited. 

In accordance with the invention, the system selectively delivers content, e.g., 
advertising, to users based on profiles inferred in the manner described above. The 
system includes a direct client communication component preferably residing at the 
20 ISP POP server 16 and a URL display component preferably residing at the client 
machine 10. 

As illustrated in FIGURE 5, the direct client communications component 
selectively retrieves selected content preferably in the form of URLs from a local 



Attorney Docket 1^(109635-123 

19 



PATENT 



advertisement database 40, and sends the it to client machines 10 using the ISP POP 
server 16. The content is displayed on the client machine 10 using the URL display 
component as will be described below. 

The direct client communications associates a client's permanent anonymous 
5 user ID and the currently assigned IP address and stores the data in the IP address 
to AID cross-reference table. 

The direct client communications component also optionally communicates 
to the ISP POP server 16 the details of a given client's computer configuration (e.g., 
which multimedia plug-ins are installed, the bandwidth of the Internet connection, 
10 etc.). This information can be used by the system to help ensure that rich-media 

content is delivered preferably only to those client machines that have the ability to 
easily and quickly display such content. 

The direct client communications component also preferably communicates 
to the client machine the availability of any new versions of URL display software 
15 and indicates how they can be downloaded. The URL display component can then 
initiate an automated download /install process for the software update if desired 
by the user. 

The URL display component, which resides on individual client machines 10, 
periodically connects to the direct client communications component and 

20 downloads a list of URLs (linked to content such as advertisements) to be displayed 
on the client machines 10. The URL display component then uses the URLs to 
retrieve the actual content pointed to by the URL, and displays the content on the 
client machine display. The content is preferably displayed in a non-obtrusive 
manner. The content can, e.g., be displayed in a separate pop-up window. FIGURE 

25 6 is a screen shot 50 of a sample banner ad pop-up. The pop-up window preferably 
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includes a "close" button, which allows a user to dismiss the window if desired. The 
window size, position, and order in the window stack are preferably remotely 
configurable. If the user clicks on the banner or some link therein (i.e., clicks- 
through), that destination is brought up in a browser window, and the user is 
5 transferred to the site of interest. 

The URL display component records feedback information on the user's 
response to the delivered content. This data can include, e.g., how long the 
advertisement was displayed and whether there was a click-through. This data is 
sent to the direct client communications component, which stores it in a local client 
10 response database 42. This data can be used for billing advertisers and/or for 
advertising campaign result tracking will be discussed below. 

Since the URL display component resides on the client machine, it is 
preferable that it make limited resource demands (e.g., on the client machine 
memory, CPU time and monitor space, Internet bandwidth, etc.). Accordingly, it is 

15 preferred that the URL display component monitors the Internet connection and 
only downloads the actual content data (pointed to by the URLs) when the 
connection is idle. Software updates are also preferably downloaded only when the 
connection is idle. Also, the URL display component preferably monitors the client 
machine CPU usage, the unused real estate on the display, the currently active 

20 application and any other relevant parameters to ensure that the content placement 
(i.e., the pop-up advertisement) and timing is both effective and not intrusive or 
annoying to the user. The URL display component also preferably monitors the 
versioning of the files required for software updates and downloads only the 
software files that have changed. 

25 The data collection, delivery and display components residing at the ISP POP 

server 16 and individual client machines 10 described above are preferably 
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designed to operate "stand-alone," i.e., independently of and without interaction 
with the master server 18 for at least some period of time. The inventive system 
however preferably synchronizes data between the master server 18 and the POP 
server 16 from time to time as illustrated in FIGURE 7. A master server 
synchronization component residing at the master server 18 and at the POP server 
16 periodically retrieves the local client profile database 34 and integrates the data 
into the master client profile database 50 located at the master server 18. It also 
retrieves the local client response database 42 and integrates the data into the master 
client response database 52. The master server synchronization component also 
parses through a master advertisement delivery database 54 looking for anonymous 
user IDs that correspond to the local POP and creates the local advertisement 
delivery database 40 on the ISP POP. It also replicates a master categorized URL 
database 56 on the local categorized URL database 32. 

This distributed architecture greatly reduces the bandwidth requirements of 
the individual ISP POP server 16 as well as the master server 18. In addition, it 
significantly enhances the scalability of the overall system. Also, it increases the 
fault tolerance of the overall system. Furthermore, is allows for rapid deployment, 
easy debug and monitoring, resulting in a very robust system. 

A dynamic campaign manager component shown in FIGURE 8 resides on 
the master server 18 and provides a portal to the system for advertisers (i.e., ad 
buyers) to select a targeted audience for a particular advertising campaign. In 
choosing the target audience, the advertiser is given various options regarding the 
demographic and psychographic characteristics of the audience. The dynamic 
campaign manager component takes information entered by an advertiser and 
creates an advertisement profile and stores this data in an Ad Campaign database 
60. This profile is used by a data analysis system component (shown in FIGURE 10) 
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to identify users who are most likely to respond to the content. The data analysis 
system takes advertising profile data from the ad campaign database 60 and 
matches it to user profiles from the master user profile database 50. (In addition, 
during the course of an advertising campaign, the data analysis system takes data 
from the master client response database 52 to refine the user profiles selection.) It 
writes results of match to the advertisement database 62. The master scheduler 
takes data from the advertisement database 62, resolves any conflicts, and writes to 
the master advertisement delivery database 54. 

The advertiser can check on the success of a current campaign through the 
dynamic campaign manager. For example, the advertiser can monitor the number 
of times content has been delivered as well as the number of click-throughs on that 
content. The system is adaptive in that the advertiser preferably can, if desired, 
change its marketing strategy (e.g., by adjusting the profile of the targeted audience) 
at various points in the campaign to optimize results. Thus, campaigns can be 
altered dynamically based on changing requirements from the advertiser or 
feedback provided by the system. 

Campaign management by an advertiser is preferably accomplished through 
a browser-based console. The advertiser can use it to define campaigns, provide 
content, and alter target groups. Feedback as to the success rate of their campaigns 
in progress is also accessible using the console. 

FIGURE 10 illustrates the billing component of the system. The billing 
component also preferably resides on the master server 18 and monitors the status 
of an advertising/content campaign, recognizes whether certain billing milestones 
have been met (e.g., whether an ad has been displayed a given number of times), 
and generates actual invoice information to be sent to advertisers. The billing 
component periodically queries the master client response database 52 to determine 
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the current status of a particular campaign. If predefined billing milestones have 
been reached, the billing component retrieves specific customer (i.e., advertiser) 
information from the advertisement campaign database 60 to generate formatted 
invoices for billing purposes. 

5 As previously discussed, in developing user profiles, the system uses data 

associating URL character strings selected by users on their client machines with a 
set of demographic and other information. Such data is available from, e.g., Neilsen 
NetRatings. The system preferably periodically queries a NetRatings or similar 
database 70 containing the data through XML to build a version of that database on 

10 the master server (the master categorized URL database 56) as shown in FIGURE 11. 
The master server synchronization component will periodically then replicate this 
database 56 on the local categorized URL database 32. 

While in the system illustrated above, the advertising delivery channel is 
through an ISP, the system could be configured such that targeted advertisements 
15 are delivered through ordinary Web pages (using banner advertisements, etc.). 

Also, in the system described above, Web site classification or profile data is 
obtained from third party vendors such as Neilsen NetRatings. However, this data 
may be alternatively generated by the system. By adding a number of users of 
known demographics, the system could be configured to generate the Web site 
20 profile data. Furthermore, the overall demographics generated for the other 

anonymous users in the system could be used to fill out gaps in the URL database, 
i.e., for Web sites having no classification data. 

Having described preferred embodiments of the present invention, it should 
be apparent that modifications can be made without departing from the spirit and 
25 scope of the invention. 



